SPECIAL3 011111 |
rs |
rt |
rd |
SUBQ.PH 01011 |
ADDU.QB 010000 |
SPECIAL3 011111 |
rs |
rt |
rd |
SUBQ_S.PH 01111 |
ADDU.QB 010000 |
6 |
5 |
5 |
5 |
5 |
6 |
SUBQ[_S].PH |
Subtract Fractional Halfword Vector | |
SUBQ.PH rd, rs, rt |
MIPSDSP |
Subtract Fractional Halfword Vector |
SUBQ_S.PH rd, rs, rt |
MIPSDSP |
Subtract Fractional Halfword Vector |
Subtract Fractional Halfword Vector
Element-wise subtraction of one vector of Q15 fractional halfword values from another to produce a vector of Q15 fractional halfword results, with optional saturation.
rd = sign_extend(sat16(rs31..16 - rt31..16)) || sat16(rs15..0 - rt15..0)
The two right-most fractional halfwords in register rt are subtracted from the corresponding fractional halfword elements in register rs.
For the non-saturating version of this instruction, each result is written to the corresponding element in register rd. In the case of overflow or underflow, the result modulo 2 is written to register rd.
For the saturating version of the instruction, the subtraction is performed using signed saturating arithmetic. If the operation results in an overflow or an underflow, the result is clamped to either the largest representable value
(0x7FFF hexadecimal) or the smallest representable value (0x8000 hexadecimal), respectively, before being written to the destination register rd.
For both instructions, the left-most result is sign-extended into the 32 most-significant bits of the destination register.
For both instructions, if any of the individual subtractions result in underflow, overflow, or saturation, a 1 is written to bit 20 in the DSPControl register within the ouflag field.
No data-dependent exceptions are possible.
The operands must be values in the specified format. If they are not, the results are UNPREDICTABLE and the values of the operand vectors become UNPREDICTABLE.
SUBQ.PH: tempB15..0 = subtract16( GPR[rs]31..16 , GPR[rt]31..16 ) tempA15..0 = subtract16( GPR[rs]15..0 , GPR[rt]15..0 ) GPR[rd]63..0 = (tempB15)32 || tempB15..0 || tempA15..0 SUBQ_S.PH: tempB15..0 = sat16Subtract( GPR[rs]31..16 , GPR[rt]31..16 ) tempA15..0 = sat16Subtract( GPR[rs]15..0 , GPR[rt]15..0 ) GPR[rd]63..0 = (tempB15)32 || tempB15..0 || tempA15..0 function subtract16( a15..0, b15..0 ) temp16..0 = ( a15 || a15..0 ) - ( b15 || b15..0 ) if ( temp16 != temp15 ) then DSPControlouflag:20 = 1 endif return temp15..0 endfunction subtract16 function sat16Subtract( a15..0, b15..0 ) temp16..0 = ( a15 || a15..0 ) - ( b15|| b15..0 ) if ( temp16 != temp15 ) then if ( temp16 = 0 ) then temp = 0x7FFF else temp = 0x8000 endif DSPControlouflag:20 = 1 endif return temp15..0 endfunction sat16Subtract
Reserved Instruction, DSP Disabled